草庐IT

apache - 强制输入url

全部标签

ruby-on-rails - 如果不存在,请将 https) 添加到 URL?

我在我的模型中使用这个正则表达式来验证用户提交的URL。我不想强制用户输入http部分,但如果它不存在,我想自己添加。validates:url,:format=>{:with=>/^((http|https):\/\/)?[a-z0-9]+([-.]{1}[a-z0-9]+).[a-z]{2,5}(:[0-9]{1,5})?(\/.)?$/ix,:message=>"isnotvalid"}知道我该怎么做吗?我对验证和正则表达式的经验很少.. 最佳答案 如果它不存在,使用前置过滤器添加它:before_validation:sma

从 URL 字符串中提取主机的 Ruby 代码

我正在寻找一种方法来可靠地从Ruby中的URL字符串中提取主机名。例如http://www.mglenn.com/directory=www.mglenn.com或者http://www.mglenn.com?param=x=www.mglenn.com 最佳答案 你可以尝试这样的事情:require'uri'myUri=URI.parse('http://www.mglenn.com/directory')printmyUri.host#=>www.mglenn.com 关于从URL字

ruby - 如何从 url 获取文件扩展名?

ruby新手,我如何从url中获取文件扩展名:http://www.example.com/asdf123.gif此外,我将如何格式化此字符串,在C#中我会这样做:string.format("http://www.example.com/{0}.{1}",filename,extension); 最佳答案 使用File.extnameFile.extname("test.rb")#=>".rb"File.extname("a/b/d/test.rb")#=>".rb"File.extname("test")#=>""File.ex

ruby-on-rails - RAILS link_to外部站点,url是用户表的属性,比如: @users.网站

我正在开发一个允许用户创建帐户的网站。创建用户时的属性之一是用户个人网站。当我尝试像这样使用用户网站时:生成的url是:http://0.0.0.0:3000/www.userswebsite.com我认为这是因为link_to的@user部分...但是我怎样才能让它链接到www.userwebsite.com? 最佳答案 如果协议(protocol)不存在,您可以在url前加上协议(protocol):moduleUrlHelperdefurl_with_protocol(url)/^http/i.match(url)?url:"

ruby - 给url添加参数

我有一个url(例如http://www.youtube.com/watch?v=og9B3BEnBHo),我想向它添加一个参数(wmode=opaque),以便它:http://www.youtube.com/watch?v=og9B3BEnBHo&wmode=opaque谁能告诉我使用哪个函数来完成这项工作? 最佳答案 require'uri'uri=URI.parse("http://www.youtube.com/watch?v=og9B3BEnBHo")uri.query=[uri.query,"wmode=opaque"

ruby-on-rails - 将任何编码的字符串强制转换为 UTF-8

在我的Rails应用程序中,我正在使用来自世界各地的RSS提要,并且一些提要具有不在UTF-8中的链接。原始提要链接不受我控制,为了在应用程序的其他部分使用它们,它们需要采用UTF-8。如何检测编码并转换为UTF-8? 最佳答案 ruby1.9“强制”编码很容易,但是它不会转换字符,只是改变编码:str=str.force_encoding('UTF-8')str.encoding.name#=>'UTF-8'如果要进行转换,使用encode:beginstr.encode("UTF-8")rescueEncoding::Undef

ruby-on-rails - Rails 点而不是 URL 中的斜线

在我的routes.rb我有:get"projects/:category_id"=>"projects#index"当我编写projects_path(1)时,生成的URL是/projects.1而不是/projects/1。你知道为什么会这样吗?这是rakeroutes的输出:GET/projects/:category_id(.:format)projects#index 最佳答案 projects_path是索引,它只接受一个参数:格式。你想要project_path(1) 关于

ruby-on-rails - Rails 3 中图像路径的完整 url

我有一张图片,其中包含载波上传:Image.find(:first).image.url#=>"/uploads/image/4d90/display_foo.jpg"在我看来,我想为此找到绝对url。附加root_url导致双/。root_url+image.url#=>http://localhost:3000//uploads/image/4d90/display_foo.jpg我不能使用url_for(据我所知),因为要么允许传递路径,或选项列表以标识资源和:only_path选项.因为我没有可以通过“controller”+“action”识别的资源,所以我不能使用:only

ruby - Kernel#gets 尝试读取文件而不是标准输入

我是Ruby的新手,今天我编写了一个应用程序,您可以通过ARGV向其传递参数。但在我的应用程序中,我希望能够使用“gets”。问题是,每次我尝试这样做时,都会出现错误。这是一个显示我的问题的简单脚本:print"Saysomething!"input=gets如果我这样调用它:$rubyscript.rbthisisarguments我收到这个错误:script.rb:2:in`gets':Nosuchfileordirectory-this(Errno::ENOENT)fromscript.rb:2希望有人能帮我解决这个问题,这样我就可以继续我的Ruby之旅。:)编辑:我知道“Get

ruby-on-rails - 您将如何解析 Ruby 中的 url 以获取主域?

我希望能够使用Ruby解析任何URL以获取没有www的域的主要部分(只是example.com) 最佳答案 请注意没有算法方法可以找到可以为特定顶级域注册域的最高级别(每个注册管理机构的政策不同),唯一的方法是创建所有顶级域的列表以及域可以注册的级别。这就是为什么PublicSuffixList存在。我是PublicSuffix的作者,一个将域分解为不同部分的Ruby库。举个例子require'uri/http'uri=URI.parse("http://toolbar.google.com")domain=PublicSuffix